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Amdt dated August 25, 2005 

Reply to Office Action of June 6, 2005 

Amendments to the Claims: 

This listing of claims will replace all prior versions, and listings, of claims in the 
application: 
Listing of Claims: 

Please amend claims 1, 2, 15, 16, 18, 19, 34, and 36 as follows: 

1. (currently amended): A computer implemented m ethod of indirect very long 
instruction word (VLIW) instruction memory (VIM) allocation comprising the steps of: 

identifying a plurality of VLIW instructions in an input source program; 

determining a lifetime of each of said plurality of VLIW instruction s* the lifetime of a 
VLIW instruction including the interval of time between loading the VLIW instructio n to VIM 
and the last time the VLIW instruction is executed: and 

allocating at least some of the plurality of VLIW instructions to VIM based on the 
lifetime of said plurality of VLIW instructions. 

2. (currently amended): The method of claim 1 wherein the step of determining the 
lifetime of each of said plurality of VLIW instructions further comprises the steps of: 

determining a control flow graph for the input source program containing said plurality of 
VLIW instructions; 

determining a VLIW flow graph for said plurality of VLIW instructions; and 
determining aVLIW interference-a graph, 

3. (original): The method of claim 2 wherein the step of determining the VLIW flow 
graph further comprises the step of: 

2 

PAGE 5/25 * RCVD AT 8/25/2005 4:08:22 PM [Eastern Daylight Time] * SVR:USPTO-EFXRF-6/31 * DNIS: 2738300 * CStD:Q19 806 1690 * DURATION (mm-ss):07-5O 



8-25-OS; 4 : O 1 PM ; PR I EST LAW OFFICES ;919 806 1690 



Appl. No. 09/886,855 

Amdt dated August 25, 2005 

Reply to Office Action of June 6, 2005 

solving VLIW flow equations. 

4. (original): The method of claim 2 wherein the control flow graph includes: 
a plurality of nodes which correspond to basic blocks of the VLIW instructions; and 

a plurality of edges, wherein each edge corresponds to a jump or a call from a given basic 
block to another basic block. 

5. (original): The method of claim 4 wherein the flow control graph at each of said 
plurality of nodes includes: 

at least one VLIW instruction defined by the node; and 
at least one VLIW instruction used by the node. 

6. (original): The method of claim 5 further comprising the step of: 
determining live-in sets and live-out sets for each of said plurality of nodes. 

7. (original): The method of claim 6 wherein the VLIW flow graph comprises the 
control flow graph and the live-in sets and live-out sets for each of said plurality of nodes. 

8. (original): The method of claim 7 wherein the step of allocating VIM further 
includes the step of: 

determining an interference graph in which every node of the interference graph 
corresponds to one of said plurality of VLIW instructions. 

9. (original): The method of claim 8 wherein the VIM comprises a plurality of VIM 
lines, and the step of determining an interference graph further comprises the steps: 

inserting an undirected edge into the interference graph between two VLIW nodes if the 
two VLIW instructions belong to a live-out set of the same node of the VLIW flow graph; and 
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coloring the interference graph nodes such that adjacent interference nodes are colored in 
different colors and each color corresponds to a different VIM line. 

10. (original): The method of claim 1 wherein the lifetime of a VLIW instruction is a 
time interval extending from when said VLIW is defined by a load VLIW instruction to when 
said VLIW is last executed by an execute VLIW instruction. 

1 1 . (previously presented): The method of claim 1 further comprising the step of: 
shortening the life of a particular VLIW by placing an initialization load VLIW (LV) 

statement adjacently prior to the use of its corresponding execute VLIW (XV) statement. 

12. (original): The method of claim 1 further comprising the step of: 
merging two non-overlapping VLIWs to share a common VIM line only when 

colorability of a resulting VLIW interference graph does not worsen as a result of said merging. 

13. (original): The method of claim 1 further comprising the step of: 
utilizing a coalescing heuristic to reduce VIM requirements of a program. 

14. (original): The method of claim 13 wherein said step of utilizing a coalescing 
heuristic results in a coalesced VIM address holding two or more of said plurality of VLIW 
instructions. 

1 5 . (currently amended): A computer implemented m ethod of optimizing the 
execution time of a user program by reducing redundant loads of very long instruction word 
(VLIW) instruction memory (VIM) comprising the steps of: 

selecting a load VLIW (LV) instruction in a current node; and 
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placing the LV instruction in a new node which is closer to a program start node if an 
execution frequency of the new node is lower than an execution frequency of the current node, 
and if a maximum number of VIM lines is not exceeded. 

16. (currently amended): A computer implemented m ethod to statically determine 
liveness of indirect very long instruction word (VLIW) instructions comprising the steps of: 

determining a control flow graph which includes nodes representing basic program 
blocks, and edges connecting the nodes which represent jumps and calls from one block to 
another block; and 

determining a live-in set and a live-out set of VLIW instructions for each node in the 
control graph to define a VLIW flow grap h, a live-in set for a node comprises the VLIW 
instructions that are used in the node, a live-out set for a node comprises a union of live-in sets of 
successor nodes, the determining step further including - bv-solving VLIW flow equation s for the 
live-in set and the live^out set 

1 7. (currently amended): The method of claim 1 6 wherein the VLIW flow equations 
comprise: 

In = U n u(O n -D n );and 

On = in succ(n) Is» 

where "n" is a given node, In is a set of live-in VLIWs at node '*n*\ On is a set of live-out 
VLIWs at node "n", U n is a set of VLIWs that are used in "n" Dn is a set of VLIWs that are 
defined in 4 *n'\ the live-out VLIWs of node "n" are all the VLIWs that belong to live-in sets of 
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successor nodes of \ and the notation u s in succ(n) Is denotes the union of all sets Is where s is a 
successor node to node n. 

18. (currently amended): A computer implemented m ethod to statically determine 
interference ef-between i ndirect very long instruction word (VLIW) instructions from a control 
graph of having a plurality of nodes, the computer implemented method c omprising the steps of: 

determining live-out sets for the plurality of nodes, the live-out sets and the control graph 
defining a VLIW flow graph: 

detennining an interference graph from the VLIW flow graph, the interference graph 
comprising VLIW nodes in which every VLIW node of the interference graph corresponds to one 
VLIW instruction; 

inserting an undirected edge into the interference graph between two VLIW nodes if the 
two VLIW instructions belong to a live-out set of the same node of the VLIW flow graph; and 

coloring the VLIW graph nodes such that adjacent VLIW nodes are colored in different 
colors and each color corresponds to a different VIM line. 

19. (currently amended): An apparatus for allocating indirect very long instruction 
word (VLIW) instruction memory (VIM) comprising: 

means for identifying a plurality of VLIW instructions in an input source program; 

means for determining a lifetime of each of said plurality of VLIW instructions , the 
lifetime of a VLIW instruction including the interval of time between loading the VLIW 
instruction to VIM and the last time the VLIW instruction is executed ; and 
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means for allocating at least some of the plurality of VLIW instructions to VIM based on 
the lifetime of said plurality of VLIW instructions. 

20. (previously presented): The apparatus of claim 19 wherein the means for 
determining the lifetime of each of said plurality of VLIW instructions further comprises: 

means for determining a control flow graph for the input source program containing said 
plurality of VLIW instructions; 

means for determining a VLIW flow graph for said plurality of VLIW instructions; and 
means for determining a VLIW interference graph. 

21 . (original): The apparatus of claim 20 wherein the means for determining the 
VLIW flow graph further comprises: 

means for solving VLIW flow equations. 

22. (original): The apparatus of claim 20 wherein the control flow graph includes: 
a plurality of nodes which correspond to basic blocks of the VLIW instructions; and 

a plurality of edges, wherein each edge corresponds to a jump or a call from a given basic 
block to another basic block. 

23. (original): The apparatus of claim 22 wherein the flow control graph at each of 
said plurality of nodes includes : 

at least one VLIW instruction defined by the node; and 
at least one VLIW instruction used by the node. 

24. (original): The apparatus of claim 23 further comprising: 

means for determining live-in sets and live-out sets for each of said plurality of nodes. 
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25 . (original): The apparatus of claim 24 wherein the VLIW flow graph comprises 
the control flow graph and the live-in sets and live-out sets for each of said plurality of nodes. 

26. (original): The apparatus of claim 25 wherein the means for allocating VIM 
further includes: 

means for determining an interference graph in which every node of the interference 
graph corresponds to one of said plurality of VLIW instructions. 

27. (original): The apparatus of claim 26 wherein the VIM comprises a plurality of 
VIM lines, and the means for determining an interference graph further comprises: 

means for inserting an undirected edge into the interference graph between two VLIW 
nodes if the two VLIW instructions belong to a live-out set of the same node of the VLIW flow 
graph; and 

means for coloring the interference graph nodes such that adjacent interference nodes are 
colored in different colors and each color corresponds to a different VIM line. 

28. (original): The apparatus of claim 19 wherein the lifetime of a VLIW instruction 
is a time interval extending from when said VLIW is defined by a load VLIW instruction to when 
said VLIW is last executed by an execute VLIW instruction. 

29. (original): The apparatus of claim 19 further comprising: 

means for merging two non-overlapping VLIWs to share a common VIM line only when 
colorability of a resulting VLIW interference graph does not worsen as a result of said merging. 

30. (original): The apparatus of claim 19 further comprising: 

means for utilizing a coalescing heuristic to reduce VIM requirements of a program. 
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3 1 . (original): The apparatus of claim 30 wherein said means for utilizing a 
coalescing heuristic produces a coalesced VIM address holding two or more of said plurality of 
VLIW instructions. 

32. (original): The apparatus of claim 19 further comprising: 

means for shortening the life of a particular VLIW by placing an initialization LV 
statement adjacently prior to the use of its corresponding XV statement. 

33. (original): An apparatus for optimizing the execution time of a user program by 
reducing redundant loads of very long instruction word (VLIW) instruction memory (VIM) 
comprising: 

means for selecting a load VIM (LV) instruction in a current node; and 

means for placing the LV instruction in a new node which is closer to a program start 

node if an execution frequency of the new node is lower than an execution frequency of the 

current node, and if a maximum number of VIM lines is not exceeded. 

34. (currently amended): An apparatus for statically determining liveness of indirect 
very long instruction word (VLIW) instructions comprising: 

means for determining a control flow graph which includes nodes representing basic 
program blocks containing VLIW instructions, and edges connecting the nodes which represent 
jumps and calls from one block to another block; and 

means for determining a live-in set and a live^out set of VLIW instructions for each node 
in the control graph to define a VLIW flow grap h, a live-in set for a node comprises the VLIW 
instructions that are used in the node, a live-out set for a node comprises a union of live-in sets of 
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successor nodes, the determining step further including- bv solving VLIW flow equation s for the 
live-in set and the live-out set . 

35. (original): The apparatus of claim 34 wherein the VLIW flow equations 
comprise: 

I„-U n u(O n -D n );and 

On = in succ(n} Is» 

where "n" is a given node, In is a set of live-in VLIWs at node "n", O n is a set of live-out 
VLIWs at node "n", U n is a set of VLIWs that are used in *V\ D n is a set of VLIWs that are 
defined in "n" the live-out VLIWs of node "n" are all the VLIWs that belong to live-in sets of 
successor nodes of 6 V, and the notation u s in SU cc(n> I s denotes the union of all sets Is where s is a 
successor node to node n. 

36. (currently amended): An apparatus statically determining interference efbetween 
indirect very long instruction word (VLIW) instructions from a control graph having a plurality 
of nodes, the apparatus c omprising: 

means for determining live-out sets for the plurality of nodes, the live-out sets and the 
control gr aph definin g a VLIW flow graph: 

means for determining an interference graph from the VLIW flow graph, the interference 
graph c omprising VLIW nodes in which every VLIW node of the interference graph corresponds 
to one VLIW instruction; 
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means for inserting an undirected edge into the interference graph between two VLIW 
nodes if the two VLIW instructions belong to a live-out set of the same node of the VLIW flow 
graph; and 

means for coloring the VLIW graph nodes such that adjacent VLIW nodes are colored in 
different colors and each color corresponds to a different VIM line. 
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